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1. A Vnethod of transferring data between a processing 
agent and a memory resource comprising: 

designatiing the memory resource for pushing the data to the 
processing agent using a push bus having a plurality of sources 
that arbitrate use of the push bus; and, 

designating the memory resource for receiving the data from 
the processing \agent using a pull bus having a plurality of 
destinations that arbitrate use of the pull bus. 

2. The method of claim 1 wherein transferring comprises: 
establishing a plurality of contexts on the programming agent and 
maintaining progmm counters and context relative registers. 

3. The methpd of claim 2 wherein the programming agent 
executes a context land issues a read command to a memory 
controller in a reap phase - 

4. The method! of claim 3 wherein the memory controller 
processes the read cd)mmand to be sent to the memory resource. 

5. The method lof claim 4 wherein the context is swapped 
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olit if the read data is required to continue the execution of the 
context . 

6. The method of claim 5 wherein after the memory 
contVoller has completed the processing of the read command, the 
memory controller pushes the data to an input transfer register 
of the\ programming agent - 
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7. \ The method of claim 6 wherein after the data has been 
pushed, the programming agent reads the data in the input 
transfer \register and the programming agent continues the 
execution \of the context. 

8. The metmod of claim 2 wherein the programming agent 
executes a contexu and loads the data into an output transfer 
register of the programming agent in a write phase. 

9. The metj:y»3\ ofv claim 8 wherein the programming agent 
issues a write comi^^rild to, a memory controller and the output 
transfer register is ket to a read-only state. 



10. The method of claim 9 wherein the context is swapped 
out if the write commanp is required to continue the execution of 
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the context, 



11. The method of claim 10 wherein the memory controller 
pushes the data from the output transfer register and the memory 
n)^s a signal to the programming agent to unlock the 
Agister. 
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12. Wie Imethod of claim 11 wherein if the context has been 
swapped outAaflter the output transfer register has been unlocked, 
the context is| swapped back in and the programming agent 
continues the execution of the context. 



13. A sys ; 

a memory re 



processing agent 
a push bus 

having a plurali 
a pull bus 



em comprising: 
source; 



a processing agent configured to transfer data between the 



and the memory resource; 

for pushing the data to the processing agent 
:y of sources that arbitrate use of the push bus; 
:or receiving the data from the processing agent 
having a plurality of destinations that arbitrate use of the pull 
bus; and j 

of microengines executing multiple contexts that 
the processing agent. 
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14. \The system of claim 13 further comprising a read phase 
for the tramsfer of data from the memory resource to the 
processing ment in which the transfer is unidirectional. 



15. ThY system of claim 13 further comprising a write phase 
for the transla^of data from the processing agent to the memory 
resource in Vh\ch the transfer is unidirectional. 
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16. The system of claim 13 further comprising a plurality 
of program countei^ and a plurality of context relative 
registers . 

17. The system\of claim 16 in which the context relative 
registers are selecteJjl from a group comprising of general purpose 
registers, inter-progr^mming agent registers, static random 
access memory (SRAM) imput transfer registers, dynamic random 
access memory (DRAM) inbut transfer registers, SRAM output 
transfer registers, DRAl^ output transfer registers, and local 
memory registers. 



18. The system of claim 17 in which the programming agent 

is configured to execute a context and issue a read command to a 
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memory controller, 



19. The syscem of claim 18 in which the memory controller 
is configured to p\:ocess the read command to be sent to the 
memory resource. 

20. The systeri of claim 19 in which the programming agent 
is configured to swa© the context out if the read command is 
required to continue ^o execution of the context. 

21. The method ofXclaim 20 in which after the read command 
is processed, the memory Vcontroller is configured to push the 
data to an input transfer \register of the programming agent and 
the programming agent is configured to read the data in the input 
transfer register and to continue the execution of the context. 




22. The system\of claim 15 in which the programming agent 
is configured to execute a context and load the data into an 
output transfer regisJ.er of the programming agent. 



23. The systert\ 6\f\ claim 22 in which the programming agent 
is configured to issue \ a write command to a memory controller and 
in which the output trapsfer register is set to a read-only 
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State. 

24. The system of claim 23 in which the programming agent 
is configured to swap the context out if the write command is 
required to contimae\ to execution of the context. 

25. The sysuem of claim 24 in which the memory controller 
is configured to push the data from the output transfer register 
and to send a signall to the programming agent to unlock the 
output transfer register. 

26. A computer program product residing on a computer 
readable medium for caVasing a parallel processor to perform a 
function comprises instructions causing the processor to: 

designate the memoiy resource for pushing the data to the 
processing agent using a\push bus having a plurality of sources 
that arbitrate use of the\push bus; and, 

designate the memory Resource for receiving the data from 
the processing agent usingla pull bus having a plurality of 
destinations that arbitrates use of the pull bus. 



27. The computer program product of claim 26 further 
comprising instructions causing the processor to establish a 
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plurality of contextsl on the programming agent and maintaining 
program counters and context relative registers. 



28. The computer program product of claim 26 wherein the 
programming agent in a read phase executes a context and issues a 



read command to a memory 



29. The computer 
memory controller process 
memory resource and the c 
command is required to co 



controller. 



pji^ogram product of claim 26 wherein the 
es the read command to be sent to the 
Dntext is swapped out if the read 
tinue the execution of the context. 



